草庐IT

JavaScript 通过 href 获取元素?

全部标签

ruby - 在 Ruby 中获取 block 返回 true 的第一个可枚举元素的最快方法是什么?

在Ruby中获取block返回true的第一个可枚举元素的最快方法是什么?例如:arr=[12,88,107,500]arr.select{|num|num>100}.first#=>107我不想像select那样遍历整个数组,因为我只需要第一个匹配项。我知道我可以做一个each并在成功时中断,但我认为有一个本地方法可以做到这一点;我只是没有在文档中找到它。 最佳答案 几个核心ruby​​类,包括Array和Hash包括Enumerable模块提供了许多有用的方法来处理这些枚举。此模块提供findordetectmethods这正是

arrays - 更改 .each 循环中引用的数组元素的值?

如何实现以下操作:我想更改在.each循环中的管道字符之间引用的数组元素的值。这是我想做的,但目前没有工作的例子:x=%w(hellothereworld)x.each{|element|if(element=="hello"){element="hi"#change"hello"to"hi"}}putsx#output:[hithereworld]很难找到如此笼统的东西。 最佳答案 您可以使用collect!或map!就地修改数组来获得您想要的结果:x=%w(hellothereworld)x.collect!{|element|

ruby - 将每个数组元素添加到 ruby​​ 文件的行中

如果我有一个字符串数组,例如a=['a','b','c','d']我想将元素输出到文件(例如.txt),每行一个。到目前为止,我有:File.new("test.txt","w+")File.open("test.txt","w+")do|i|i.write(a)end这为我提供了test.txt文件中一行的数组。我如何遍历数组,将每个值添加到文件的新行? 最佳答案 要么使用Array#each遍历你的数组并调用IO#puts将每个元素写入文件(puts添加记录分隔符,通常是换行符):File.open("test.txt","w+

ruby - 如何通过 Rack 提供静态文件?

我目前正在开发一个基于Rack的应用程序,并希望将所有文件请求(例如filename.filetype)重定向到指定的文件夹。Rack::Static仅支持对特殊文件夹(例如“/media”)的文件请求。我是否必须编写自己的Rack中间件或是否存在开箱即用的解决方案? 最佳答案 要将每个请求重定向到特定路径,请使用Rack::File(出于某种原因,最近的文档中没有此类,但它是stillpartof最新的Rack):runRack::File.new("/my/path")要重定向每个请求,并在目标目录中添加所有文件的HTML索引,

ruby-on-rails - 在 Ruby 中参数化获取请求?

如何在Ruby中发出带参数的HTTPGET请求?POSTing时很容易做到:require'net/http'require'uri'HTTP.post_formURI.parse('http://www.example.com/search.cgi'),{"q"=>"ruby","max"=>"50"}但我看不到使用'net/http'将GET参数作为散列传递的方法。 最佳答案 从版本1.9.2(我认为)开始,您实际上可以将参数作为散列传递给URI::encode_www_form像这样的方法:require'uri'uri=UR

ruby-on-rails - 您将如何解析 Ruby 中的 url 以获取主域?

我希望能够使用Ruby解析任何URL以获取没有www的域的主要部分(只是example.com) 最佳答案 请注意没有算法方法可以找到可以为特定顶级域注册域的最高级别(每个注册管理机构的政策不同),唯一的方法是创建所有顶级域的列表以及域可以注册的级别。这就是为什么PublicSuffixList存在。我是PublicSuffix的作者,一个将域分解为不同部分的Ruby库。举个例子require'uri/http'uri=URI.parse("http://toolbar.google.com")domain=PublicSuffix

ruby - 从 href html 标签中使用 ruby​​ 中的 nokogiri 提取链接(URL)?

我想从网页中提取所有URL,如何使用nokogiri做到这一点?例子:site1site2site3resultshouldbeanlist:l=['http://example.org/site/1/','http://example.org/site/2/','http://example.org/site/3/' 最佳答案 你可以这样做:doc=Nokogiri::HTML.parse(site1site2site3site4site5site6HTML_ENDl=doc.css('div.heata').map{|link|

ruby - 在 Ruby 中的第一个 = 符号之后获取子字符串

纯粹出于好奇,有没有更优雅的方法来简单地获取字符串中第一个=符号之后的子字符串?以下工作回馈name=bob:string="option=name=bob"string[string.index('=')+1..-1]只是感觉不太像Ruby。这也有效:string.split('=',2)[1]同样,不是很优雅,特别是因为split正在做额外的不必要的工作。正则表达式是答案吗?对于在字符串中查找单个字符位置的简单性,我觉得这有点矫枉过正:string.match('=(.*)')[1]我不得不想象这是一个极其普遍的情况,不是有一个string.after('=')类型的方法吗?鉴于此

ruby - 将方法应用于数组/可枚举中的每个元素

这是我的数组:array=[:one,:two,:three]我想将to_s方法应用于我的所有数组元素以获取array=['one','two','three']。我该怎么做(将可枚举的每个元素转换为其他元素)? 最佳答案 这会起作用:array.map!(&:to_s) 关于ruby-将方法应用于数组/可枚举中的每个元素,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/64969

ruby-on-rails - 如何获取包含表的列名的数组

我需要一个包含表的列名的数组关于如何使用rails3.0.0rc做到这一点有什么想法吗? 最佳答案 假设您有一个Post模型:Post.column_names#orPost.columns.map{|column|column.name}它将返回一个数组,其中包含表“posts”的列名。 关于ruby-on-rails-如何获取包含表的列名的数组,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/qu